

#### 香港中文大學

The Chinese University of Hong Kong

CENG3430 Rapid Prototyping of Digital Systems

# Lecture 01: Introduction to VHDL





#### **Outline**



- Basic Structure of a VHDL Module
  - 1) Library Declaration
  - 2) Entity Declaration
    - External Signal (I/O Pins)
  - 3) Architecture Body
    - Internal Signal
    - Architectural Design Methods
      - ① Data Flow Design (concurrent statements)
      - ② Structural Design ("port map")
      - 3 Behavioral Design (sequential statements)
    - Concurrent vs. Sequential Statements
    - Design Constructions

#### **Basic Structure of a VHDL Module**



#### A VHDL file

#### 1) Library Declaration

```
library IEEE;
use IEEE.std_logic_1164.all;
use IEEE.std_logic_arith.all;
use IEEE.std_logic_unsigned.all;
```

#### 2) Entity Declaration

Define the <u>signals</u> that can be seen outside <u>externally</u> (I/O pins)

#### 3) Architecture Body

Define the <u>internal signals and</u> operations of the desired function



## Example: 4-bit Comparator in VHDL (1/2)

Schematic Circuit of a 4-bit Comparator



- \*Recall: Exclusive NOR (XNOR)
- When A=B, Output Y=0
- Otherwise, Output Y = 1



#### Truth Table

| Α | В | Y |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

VHDL for programmable logic, Skahill, Addison Wesley

## Example: 4-bit Comparator in VHDL (2/2)

Code of 4-bit Comparator in VHDL:

```
eqcomp4.vhd
             1 --the code starts here , "a comment"
Library
             2 library IEEE;
Declaration
             3 use IEEE.std logic 1164.all;
                entity egcomp4 is
Entity
             5 port (a, b: in std logic vector(3 downto 0);
Declaration
                    equals: out std logic);
                end eqcomp4;
                architecture arch eqcomp4 of eqcomp4 is
               begin
Architecture
             10
                   equals \leftarrow '1' when (a = b) else '0';
Body
             11 -- "comment line"
             12 end arch eqcomp4;
```

#### **Outline**



- Basic Structure of a VHDL Module
  - 1) Library Declaration
  - 2) Entity Declaration
    - External Signal (I/O Pins)
  - 3) Architecture Body
    - Internal Signal
    - Architectural Design Methods
      - Data Flow Design (concurrent statements)
      - ② Structural Design ("port map")
      - 3 Behavioral Design (sequential statements)
    - Concurrent vs. Sequential Statements
    - Design Constructions

## **Entity Declaration**



```
entity enclosed by the identifier eqcomp4 (entered by the user)
                  port defines the external signals (i.e., I/O pins)
                  -- the code starts here , "a comment"
Library
                  library IEEE;
Declaration
                  use IEEE.std logic 1164.all;
                  entity eqcomp4 is
              5 → port→(a, b: in std logic_vector(3 downto 0);
Entity
Declaration
                       → equals: out std logic);
                  end eqcomp4;
Architecture
Body
                         a, b, equals are the identifiers of external signals
                         std_logic, std_logic_vector are the logic types
                         of external signals
                         in, out are the modes of external signals
```

#### **Identifiers**



Identifiers: Used to name any object in VHDL

- Naming Rules:
  - 1) Made up of only alphabets, numbers, and underscores
  - 2) First character must be a letter
  - 3) Last character CANNOT be an underscore
  - 4) Two connected underscores are NOT allowed
  - 5) VHDL-reserved words are NOT allowed
  - 6) VHDL is **NOT** case sensitive
    - Txclk, Txclk, TXCLK, TxClk are all equivalent

#### **VHDL** Reserved Words



abs
access
after
alias
all
and
architecture
array
assert
attribute
begin

begin block body buffer bus

case component configuration constant

disconnect downto

else elsif end entity exit file for function

generate generic guarded

if impure in inertial inout is

label library linkage literal loop

map mod

nand new next nor not null of on open or others out

package port postponed procedure process pure

range record register reject rem report return rol ror select severity shared signal sla sll sra srl subtype

then

to

transport type unaffected units until use

> wait when while with

variable

xnor xor

## Class Exercise 1.1

| Student ID: | <br>Date: |
|-------------|-----------|
| Name:       |           |

- Determine whether the following identifiers are legal or not. If not, please give your reasons.
  - tx\_clk
  - \_tx\_clk
  - Three\_State\_Enable
  - 8B10B
  - sel7D
  - HIT 1124
  - large#number
  - link\_\_bar
  - select
  - rx\_clk\_

## External Signals (I/O Pin)



- An external signal (or I/O pin) is a physical wire that can carry logic information.
- Many logic types are eligible for external signals, e.g.,
  - bit: can be logic '1' or '0' only
  - std\_logic: can be logic 'U', 'X', '0', '1', 'Z', 'W', 'L', 'H', or '-'
    - 9-valued standard logic (IEEE standard 1164)
    - E.g., equals: out std logic;
  - std\_logic\_vector: a group of wires (i.e., a signal bus)
    - E.g., a, b: in std\_logic\_vector(3 downto 0);
       Each of a(3), a(2), a(1), a(0) is a std\_logic signal.
- VHDL is strongly-typed language.
  - Signals of <u>different base types</u> CANNOT to assigned to each other without the use of type-conversion.

## IEEE 1164: 9-valued Logic Standard



'U': Uninitialized

'X': Forcing Unknown

• '0': Forcing 0

• '1': Forcing 1

'Z': High Impedance (Float)
 '-': Don't care

'W': Weak Unknown

'⊥': Weak 0

'H': Weak 1

| VHDL Resolution Table |   |   |   |   |   |   |   |   |   |
|-----------------------|---|---|---|---|---|---|---|---|---|
|                       | U | X | 0 | 1 | Z | W | L | H | _ |
| U                     | U | U | U | U | U | U | U | U | U |
| X                     | U | X | X | X | X | X | X | X | X |
| 0                     | U | X | 0 | X | 0 | 0 | 0 | 0 | X |
| 1                     | U | X | X | 1 | 1 | 1 | 1 | 1 | X |
| Z                     | U | X | 0 | 1 | Z | W | L | Н | X |
| W                     | U | X | 0 | 1 | M | W | W | M | X |
| L                     | U | X | 0 | 1 | L | W | L | W | X |
| Н                     | U | X | 0 | 1 | Н | W | W | Н | X |

Rule: When 2 signals meet, the forcing signal dominates.

## Resolved Logic Concept



- Resolved Logic (Multi-value Signal): Multiple outputs can be connected together to drive a signal.
  - The resolution function is used to determine how multiple values from different sources (drivers) for a signal will be reduced to one value.
- Single-value Signal Assignment:

Multi-value Signal Assignment:

← We need to "resolve" it!



signal a, b, c: bit;

## std\_logic vs. std\_ulogic (1/2)





- std\_logic: a type of resolved logic, that means a signal can be driven by 2 inputs.
- std\_ulogic ("u" means unresolved): a type of unresolved logic, that means a signal CANNOT be driven by 2 inputs.

## std\_logic vs. std\_ulogic (2/2)



How to use it?

```
library IEEE;
use IEEE.std_logic_1164.all;
entity
```

architecture

#### **Class Exercise 1.2**

| Student ID: | Date: |
|-------------|-------|
| Name:       |       |

```
1 library IEEE;
2 use IEEE.std_logic_1164.all;
3 entity eqcomp4 is
4 port (a, b: in std_logic_vector(3 downto 0);
5 equals: out std_logic);
6 end eqcomp4;
7 architecture arch_eqcomp4 of eqcomp4 is
8 begin
9 equals <= '1' when (a = b) else '0';
10 end arch_eqcomp4;</pre>
```

- How many input and output pins are there in the code?
   Answer:
- What are their names and their types?
   Answer:
- What is the difference between std\_logic and std\_logic\_vector?
   Answer: \_\_\_\_\_\_

#### **Modes of I/O Pins**



 Modes of I/O pin must be <u>explicitly specified</u> in port of entity declaration:

#### Example:

```
entity eqcomp4 is
  port (a, b: in std_logic_vector(3 downto 0);
        equals: out std_logic);
end eqcomp4;
```

- There are 4 available modes of I/O pins:
  - 1) in: Data flows in only
  - 2) out: Data flows out only (cannot be read back by the entity)
  - 3) inout: Data flows bi-directionally (i.e., in or out)
  - 4) buffer: Similar to out but it can be read back by the entity

#### Class Exercise 1.3

| Student ID: | Date: |
|-------------|-------|
| Name:       |       |

 Based on the following schematic, identify the modes of the IO pins.



#### **Outline**



- Basic Structure of a VHDL Module
  - 1) Library Declaration
  - 2) Entity Declaration
    - External Signal (I/O Pins)

#### 3) Architecture Body

- Internal Signal
- Architectural Design Methods
  - Data Flow Design (concurrent statements)
  - ② Structural Design ("port map")
  - 3 Behavioral Design (sequential statements)
- Concurrent vs. Sequential Statements
- Design Constructions

## **Architecture Body**



 Architecture Body: Defines the <u>internal</u> of the chip Example: the architecture body of the entity **eqcomp4**

```
architecture arch_eqcomp4 of eqcomp4 is
begin
   equals <= '1' when (a = b) else '0';
   -- "comment line"
end arch_eqcomp4;</pre>
```

- arch\_eqcomp4: the architecture identifier (entered by the user)
- equals, a, b: I/O pins designed by the user in the entity declaration
- begin ... end: define the internal operation
- equals  $\leftarrow$  '1' when (a = b) else '0';
  - <= here means "signal assignment" not "less than or equal".</li>
  - when-else is a concurrent design construction.
- --: comment on a line

## **Built-in Operators**



- Logical Operators: and, or, nand, nor, xor, xnor, not have their usual meanings.
- Relation Operators (result is Boolean)

= equal

<= less than or equal

/= not equal

> greater than

< less than

>= greater than or equal

- Logical Shift and Rotate
  - sll shift left logical, fill blank with 0
  - srl shift right logical, fill blank with 0
  - rol rotate left logical, circular operation
    - E.g., "10010101" rol 3 is "10101100"
  - ror rotate right logical, circular operation

#### **Outline**



- Basic Structure of a VHDL Module
  - 1) Library Declaration
  - 2) Entity Declaration
    - External Signal (I/O Pins)
  - 3) Architecture Body
    - Internal Signal
    - Architectural Design Methods
      - ① Data Flow Design (concurrent statements)
      - ② Structural Design ("port map")
      - 3 Behavioral Design (sequential statements)
    - Concurrent vs. Sequential Statements
    - Design Constructions

Keys to design complicated architecture body!

## Internal Signal



- The entity declares the external signals.
- The architecture body can also declare signals that can be used internally.

```
architecture arch_eqcomp4 of eqcomp4 is
-- Internal signals shall be declared here!
begin
...
end arch_eqcomp4;
```

- Signal: Represent physical wires
  - E.g., signal s1: BIT := '1';
- Constant: Hold unchangeable values
  - E.g., constant c1: BIT := '1';

## Signal Object



```
signal SIG_NAME: <type> [:= <value>];
```

Note: Signals can be declared without initialized values.

#### Examples:

```
- signal SIG NAME: STD LOGIC;
```

Declared without initialized value

```
- signal SIG NAME: STD LOGIC := '1';
```

#### Signals can be declared

- In the "port" of the entity declaration (as external signals);
- Or in the architecture body (as internal signals).

## **Constant Object**



```
constant CONST_NAME: <type> := <value>;
Note: Constants must be declared with initialized values.
```

#### Examples:

```
- constant CONST_NAME: STD_LOGIC := 'Z';
- constant CONST_NAME: STD_LOGIC_VECTOR (3
  downto 0) := "0-0-";
     '-' means "don't care"
```

- Constants can be declared in
  - Anywhere allowed for declaration.

#### Class Exercise 1.4

Student ID: \_\_\_\_\_ Date: Name: \_\_\_\_

```
entity nandgate is
       port (in1, in2: in STD LOGIC;
                  out1: out STD LOGIC);
   end nandgate;
   architecture nandgate arch of nandgate is
6
   begin
       connect1 <= in1 and in2;</pre>
       out1<= not connect1;
  end nandgate arch;
```

- Declare an internal signal named "connect1" in Line 6.
- Can you assign an I/O mode to this signal? Why?

Draw the schematic circuit for the code.

#### **Outline**



- Basic Structure of a VHDL Module
  - 1) Library Declaration
  - 2) Entity Declaration
    - External Signal (I/O Pins)
  - 3) Architecture Body
    - Internal Signal
    - Architectural Design Methods
      - ① Data Flow Design (concurrent statements)
      - ② Structural Design ("port map")
      - 3 Behavioral Design (sequential statements)
    - Concurrent vs. Sequential Statements
    - Design Constructions

## ① Data Flow (Concurrent Statements)

- Data flow design method uses concurrent statements rather than sequential statements.
  - Concurrent statements can be interchanged freely.
  - There's no "execution order" for concurrent statements.

```
1 library IEEE; %Vivado2014.4 tested ok
  use IEEE.STD LOGIC 1164.ALL;
  entity eqb comp4 is
  port (a, b: in std logic vector(3 downto 0);
         equals, bigger: out std logic);
 5
  end eqb comp4;
  architecture dataflow4 of eqb comp4 is
  begin
     equals <= '1' when (a = b) else '0'; --concurrent
10 bigger <= '1' when (a > b) else '0'; --concurrent
11 end dataflow4;
                              Lines 9 & 10 will be executed whenever
```

CENG3430 Lec01: Introduction to VHDL 2021-22 T2 signal a or b (or both) changes.

32

#### Class Exercise 1.5

Student ID: \_\_\_\_\_ Date: Name:

#### Draw the schematic circuit of this code:

```
1 library IEEE; --Vivado 14.4
 2 use IEEE.STD LOGIC 1164.ALL;
  entity abc is
    port (a,b,c: in std logic;
 5
               y: out std logic);
  end abc;
 7 architecture abc arch of abc is
  signal x : std logic;
  begin
10 x \le a \text{ nor } b;
11 y \le x and c;
12 end abc arch;
```

Answer:

# ② Structural Design (use "port map") \_



Structural Design: Like a circuit but describe it by text.



Connected by **port map** in the architecture body of the top-level design module

#### Design Steps:

Step 1: Create entities

Step 2: Create components from entities

Step 3: Use "port map" to relate the components

## **Step 1: Create Entities**



```
1 library IEEE;
 2 use IEEE.STD LOGIC 1164.ALL;
 3 entity and2 is
 4 port (a,b: in STD LOGIC;
       c: out STD LOGIC );
 6 end and2;
 7 architecture and2 arch of and2 is
 8 begin
  c \le a and b;
10 end and2 arch;
12 library IEEE;
13 use IEEE.STD LOGIC 1164.ALL;
14 entity or2 is
15 port (a,b: in STD LOGIC;
  c: out STD LOGIC );
16
17 end or2;
18 architecture or 2 arch of or 2 is
19 begin
20 c \le a \text{ or } b;
21 end or2 arch;
CENG3430 Lec01: Introduction to VHDL 2021-22 T2
```





## **Step 2: Create Components**



```
component and2 --create components--
   port (a,b: in std logic; c: out std logic);
end component;
component or2 --create components--
   port (a,b: in std logic; c: out std logic);
end component;
signal con1 signal: std logic; --internal signal--
                                      (optional) --
         AND2
                                   OR<sub>2</sub>
```

## **Step 3: Connect Components**



#### label1 & label 2 are line labels

Lines can be interchanged for the same circuit design.



## Put Together: A Running Example



```
1 library IEEE;
                                     1 library IEEE;
                                                                  Top-level Module
                                     2 use IEEE.STD LOGIC 1164.ALL;
 2 use IEEE.STD LOGIC 1164.ALL;
 3 entity and2 is
                            Step 1
 4 port (a,b: in STD LOGIC;
                                     4 entity test is
   c: out STD LOGIC );
                                     5 port (in1: in STD LOGIC; in2: in STD LOGIC;
                                        in3: in STD LOGIC;
 6 end and2;
 7 architecture and2 arch of and2 is
                                     7 out1: out STD LOGIC );
 8 begin
                                     8 end test;
   c \le a and b;
                                     9 architecture test arch of test is
10 end and2 arch;
                                    10 component and 2-create component
                                                                              Step 2
                                       port (a,b: in std logic; c: out std logic);
12 library IEEE;
                                    12 end component;
13 use IEEE.STD LOGIC 1164.ALL;
                                    13 component or2 --create component
14 entity or2 is
                                    port (a,b: in std logic; c: out std logic);
                            Step 1
                                    15 end component;
15 port (a,b: in STD LOGIC;
c: out STD LOGIC );
                                    16 signal inter sig: std logic;
                                                                              Step 3
                                    17 begin
17 end or2;
                                    label1: and2 port map (in1, in2, inter sig);
18 architecture or 2 arch of or 2 is
19 begin
                                    19 label2: or2 port map (inter sig, in3, out1);
20 c <= a or b;
                                    20 end test arch;
                                                                    inter sig
                                                              in1 -
21 end or2 arch;
CENG3430 Lec01: Introduction to VHDL 2021-22 T2
```

## **Class Exercise 1.6**

Student ID: \_\_\_\_\_ Date: Name: \_\_\_\_

Draw the schematic diagram for the statements:

```
i label_u0: and2 port map (a, c, x);
ii label_u1: or2 port map (b, x, y);
```

- When will Lines i and ii be executed?
- Answer:
  - Line i:
  - Line ii:

## **Another Running Example**



```
entity test andand2 is
                                            inter sig
port (in1: in STD LOGIC;
                                 in1
                                 in2
       in2: in STD LOGIC;
                                                              out1
                                 in3
       in3: in STD LOGIC;
      out1: out STD LOGIC
  );
end test andand2;
architecture test and and 2 arch of test and and 2 is
component and2
                                                  No need to create the
                                                  component for the same
  port (a, b: in std_logic; c: out std_logic);
                                                  entity for several times
end component ;
signal inter sig: std logic;
begin
                                                        But you can use
    label1: and2 port map (in1, in2, inter sig);
                                                        the component
    label2: and2 port map (inter sig, in3, out1);
                                                        multiple times
```

end test andand2 arch;

### ② Structural vs. ① Data Flow



#### ② Structural

```
("port map")
```

```
architecture test arch of test is
component and2
 port (a,b: in std logic;
          c: out std logic);
end component;
component nor2
 port (a,b: in std logic;
          c: out std logic);
end component;
signal x: std logic;
begin
  label1: nor2 port map (a, b, x);
  label2: and2 port map (x, c, y);
end test arch;
```

#### ① Data Flow

#### (concurrent statements)

```
architecture test arch of test is
signal x : std logic;
begin
  x \le a \text{ nor } b;
  y \le x and c;
end test arch;
```



# ③ Behavioral Design (use "process")



- Behavioral design is sequential
  - Just like a sequential program



- The keyword is "process":
  - The main character is "process (sensitivity list)".
  - A process is executed when one (or more) of the signals in the sensitivity list changes.
  - Statements inside a process are sequentially executed.

## Behavioral Design Example



```
library IEEE; --vivado14.4
use IEEE.STD LOGIC 1164.ALL;
entity eqcomp4 is
port (a, b: in std logic vector(3 downto 0);
    equals: out std logic);
end eqcomp4;
architecture behavioral of egcomp4 is
begin
  process (a, b) ← Behavioral Design: Sequential in a "process"
  begin
    if a = b then
        equals <= '1';
                             Sequential Execution:
                             Statements inside a process are
    else
        equals <= '0';
                             sequentially executed.
    end if;
  end process;
end behavioral;
```

## **Another Example? See Lab01**



#### Hardware

```
entity AND Gate is
    port ( A: in STD LOGIC;
           B: in STD LOGIC;
           C : out STD LOGIC);
end AND Gate;
architecture AND arch of
AND Gate is
begin
    C \le A and B;
end AND arch;
```

- 1) It is legal to have a process WITHOUT a sensitivity list.
- 2) Such process MUST have some kinds of time-delay or wait (see Lec03 for more examples).

#### Simulation

```
architecture Behavioral of AND TEST is
component AND Gate
    port(A, B: in STD LOGIC;
            C: out STD LOGIC);
end component;
signal ai, bi: STD LOGIC;
signal ci: STD LOGIC;
begin
    AND Gate port map (A => ai, B => bi,
                        C \Rightarrow ci);
    process
    begin
        ai <= '0'; bi <= '0';
        wait for 100 ns;
       ai <= '1'; bi <= '0';
       wait for 100 ns;
       ai <= '0'; bi <= '1';
       wait for 100 ns;
        ai <= '1'; bi <= '1';
        wait;
    end process;
```

### **Outline**



- Basic Structure of a VHDL Module
  - 1) Library Declaration
  - 2) Entity Declaration
    - External Signal (I/O Pins)
  - 3) Architecture Body
    - Internal Signal
    - Architectural Design Methods
      - Data Flow Design (concurrent statements)
      - ② Structural Design ("port map")
      - 3 Behavioral Design (sequential statements)
    - Concurrent vs. Sequential Statements
    - Design Constructions

# Concurrent vs. Sequential Statements

#### Concurrent Statement

- 1) Statements inside the architecture body can be executed concurrently, except statements enclosed by a process.
- 2) Every statement will be <u>executed once</u> whenever <u>any</u> signal in the right-hand-side of statement changes.

#### Sequential Statement

- 1) Statements within a process are executed sequentially, and the result is obtained when the process is complete.
- 2) process (sensitivity list): Whenever any signals in the sensitivity list changes its state, the process executes once.
- 3) Aprocess can be treated as one concurrent statement in the architecture body.

## **Concurrent with Sequential**



```
1 library IEEE; --vivado14.4 ok
                                            out1
                                   in1
                                                      out2
 2 use IEEE.STD LOGIC 1164.ALL;
                                   in2.
                                    in3
 3 entity conc ex is
 4 port (in1, in2, in3: in std logic;
 5
          out1, out2 : inout std logic);
 6 end conc ex;
 7 architecture for ex arch of conc ex is
 8 begin
 9 process (in1, in2)
                               The process (9-12) and
10 begin
                               line 13 are concurrent
11   out1 <= in1 and in2;</pre>
                               and can be interchanged!
12 end process;
13 out2 <= out1 and in3; -- concurrent statement
14 end for ex arch;
```

## **Class Exercise 1.7**

Student ID: \_\_\_\_\_ Date: Name: \_\_\_\_

 Use structural, data flow, and behavioral designs to implement the following circuit in VHDL:



### **Outline**



- Basic Structure of a VHDL Module
  - 1) Library Declaration
  - 2) Entity Declaration
    - External Signal (I/O Pins)
  - 3) Architecture Body
    - Internal Signal
    - Architectural Design Methods
      - Data Flow Design (concurrent statements)
      - ② Structural Design ("port map")
      - 3 Behavioral Design (sequential statements)
    - Concurrent vs. Sequential Statements
    - Design Constructions

# **Design Constructions**



- Concurrent: Statements that can be stand-alone
  - 1) when-else

2) with-select-when

Concurrent: **OUTSIDE** process

- Sequential: Statements inside the process
  - 1) if-then-else
  - 2) case-when

3) for-in-to-loop

Sequential – **INSIDE** process

## Concurrent 1) when-else



```
in1 out1
```

```
1 library IEEE;
 2 use IEEE.STD LOGIC 1164.ALL;
 3 entity when ex is
 4 port (in1, in2 : in std logic;
             out1 : out std logic);
 6 end when ex;
 7 architecture when ex arch of when ex is
                            Condition based
 8 begin
  out1 <= '1' when in1 = '1' and in2 = '1' else '0';
10 end when ex arch;
                       when condition is true then out1 <= '1'
                       otherwise then out1 <= '0'
```

## Class Exercise 1.8

Student ID: \_\_\_\_\_ Date: Name: \_\_\_\_

• Fill in line 9 using when-else:

```
1 library IEEE;
2 use IEEE.STD LOGIC 1164.ALL;
3 entity when ex is
4 port (in1, in2 : in std logic;
            out1 : out std logic);
6 end when ex;
7 architecture when ex arch of when ex is
8 begin
9
```

10 end when\_ex\_arch;

## Concurrent 2) with-select-when



```
in1
                                  out1
 1 library IEEE;
 2 use IEEE.STD LOGIC 1164.ALL;
 3 entity when ex is
 4 port (in1, in2: in std logic;
             out1 : out std logic);
 6 end when ex;
 7 architecture when ex arch of when ex is
  begin
     with in1 select Signal based
       out1 <= in2 when '1', ← when in1='1' then out1 <= in2
10
                '0' when others; ← when in1 = other cases
11
                                    then out1 <= '0'
12 end when ex arch;
```

### Class Exercise 1.9

Student ID: \_\_\_\_\_ Date: Name: \_\_\_\_

• Fill in lines 10~11 using with-select-when:

```
1 library IEEE;
                                    in1
 2 use IEEE.STD LOGIC 1164.ALL;
 3 entity when ex is
 4 port (in1, in2 : in std logic;
             out1 : out std logic);
 6 end when ex;
 7 architecture when ex arch of when ex is
 8 begin
 9 with in1 select
10
11
```

CENG3430 Lec01: Introduction to VHDL 2021-22 T2

12 end when ex arch;

### when-else VS. with-select-when



• Concurrent 1) when-else: Condition based

out1 <= '1' when in1 = '1' and in2 = '1' else '0';

when in1='1' and in2='1' then out1 <= '1', otherwise out <= '0'</pre>

• Concurrent 2) with-select-when: Signal based

# **Design Constructions**



- Concurrent: Statements that can be stand-alone
  - 1) when-else

2) with-select-when

Concurrent: **OUTSIDE** process

- Sequential: Statements inside the process
  - 1) if-then-else
  - 2) case-when

3) for-in-to-loop

Sequential – **INSIDE** process

## Sequential 1) if-then-else



```
in1 -
                           out1
        in2
entity if ex is
    port(in1, in2: in std logic;
            out1: out std logic);
end if ex;
architecture if ex arch of if ex is
begin
    process (b)
    begin
        if in1 = '1' and in2 = '1' then
            out1 <= '1';
        else
            out1 <= '0';
        end if;
end process;
end if ex arch;
```

```
if (cond) then
    statement;
end if;
if (cond) then
    statement1;
else
    statement2;
end if;
if (cond1) then
    statement1;
elsif (cond2) then
    statement2;
elsif ...
else
    statementn;
```

end if;

## Sequential 2) case-when



```
entity test case is
    port (in1, in2: in std logic;
          out1, out2: out std logic);
end test case;
architecture case arch of test case is
signal b: std logic vector (1 downto 0);
begin
                        00"|"11" means case "00" or "11"
    process (b)
    begin
                         ... "=>" means "implies" not "bigger"
        case b is
        when "00" | "11"
                       => out1 <= '0';
                          out2 <= '1';
        when others
                       >> out1 <= '1';
                          out2 <= '0';
        end case;
                        All cases must be present:
   end process;
                        Use others to complete all cases
   b <= in1 & in2;
end case arch;
```

### **Class Exercise 1.10**

Student ID: \_\_\_\_\_ Date: Name: \_\_\_\_

```
1 entity test case is
      port (in1, in2: in std logic;
            out1, out2: out std logic);
 4 end test case;
 5 architecture case arch of test case is
 6 signal b: std logic vector (1 downto 0)
 7 begin
 8
      process (b)
      begin
10
          case b is
          when "00"|"11" => out1 <= '0';
11
12
                            out2 <= '1';
13
          when others => out1 <= '1';
14
                            out2 <= '0';
15
          end case;
16 end process;
17
  b <= in1 & in2;
18 end case arch;
```

| • | List line numbers of |
|---|----------------------|
|   | concurrent           |
|   | statements:          |
| 5 | Answer:              |
| , |                      |

Fill in the truth table:

| ٠. | I III III tile tidtii table. |      |      |      |  |
|----|------------------------------|------|------|------|--|
|    | b(1)                         | b(0) | out1 | out2 |  |
|    | 0                            | 0    |      |      |  |
|    | 0                            | 1    |      |      |  |
|    | 1                            | 0    |      |      |  |
|    | 1                            | 1    |      |      |  |

## Concurrent vs. Sequential Constructions



b <= "1000"

#### Concurrent

#### when-else

#### $b \ll "1000" \text{ when } a = "00" \text{ else}$

"0100" when a = "01" else

"0010" when a = "10" else

"0001" when a = "11";

#### with-select-when

#### with a select

b <= "1000" when "00",

"0100" when "01",

"0010" when "10",

"0001" when "11";

#### **Sequential**

#### if-then-else

if a = "00" then  $b \Leftarrow "1000"$  elsif a = "01" then  $b \Leftarrow "1000"$ 

elsif a = "10" then  $b \Leftarrow "1000"$ 

else

end if;

### case-when

#### case a is

when "00" => b <= "1000";

when "01"  $\Rightarrow$  b  $\Leftarrow$  "0100";

when "10"  $\Rightarrow$  b  $\Leftarrow$  "0010";

when others => b <= "0001";

# **Sequential 3) 100p (1/2)**

```
library IEEE;
                                             in1(3:0)
                                                     out1(3:0)
use IEEE.STD LOGIC 1164.ALL;
entity for ex is
port (in1: in std logic vector(3 downto 0);
     out1: out std logic vector(3 downto 0));
end for ex;
architecture for ex arch of for ex is
begin
```

```
process (in1) for-loop
begin
  for i in 0 to 3 loop
    out1(\mathbf{i}) \le not in1(\mathbf{i});
  end loop;
end process;
```

```
process (in1) while-loop
variable i: integer := 0;
begin
    i := 0;
    while i < 4 loop
      out1(i) \le not in1(i);
      i := i + 1;
    end loop;
```

CENG3430 Lec01: Introduction to VHDL 2021-22 T2 end process;

end for ex arch;

# **Sequential 3) 100p (2/2)**



for-loop

```
for <u>i</u> in 0 to 3 loop
  out1(i) <= not in1(i);
end loop;</pre>
```

- No need to declare the loop index (e.g., i).
  - It is implicitly declared within the loop.
  - It may not be modified within the loop (e.g., i := i-1;).
- for-loop is generally supported for synthesis.

while-loop

```
variable i: integer:=0;
...
while i < 4 loop
  out1(i) <= not in1(i);
...
end loop;</pre>
```

- The while loop repeats if the condition tested is true.
  - The condition is tested before each iteration.
- while-loop is supported
   by some logic synthesis
   tools with restrictions.

https://www.ics.uci.edu/~jmoorkan/vhdlref/for\_loop.html https://www.ics.uci.edu/~jmoorkan/vhdlref/while.html

## **Variable Object**



```
variable VAR_NAME: <type> [:= <value>];
```

Note: Variables can be declared without initialized values.

#### Examples:

- variable VAR NAME: STD LOGIC;
  - Declared without initialized value
- variable VAR NAME : STD LOGIC := '1';
- Variables can only be declared/used in the process.
- Variables are used only by programmers for internal representation (less direct relationship to hardware).

# Signal vs. Variable Assignment



 Both signals and variables can be declared without initialized values.

```
- signal SIG_NAME: <type> [:= <value>];
- variable VAR_NAME: <type> [:= <value>];
```

- Their values can be assigned after declaration.
  - Syntax of signal assignment:

```
SIG NAME <= <expression>;
```

– Syntax of variable assignment:

```
VAR NAME := <expression>;
```

## **Class Exercise 1.11**

Student ID: \_\_\_\_\_ Date: Name: \_\_\_\_

Rewrite arch1 without using a process()

```
architecture arch1 of ex1
                             architecture arch1 of ex1
is
                             is
begin
                             begin
  process (in1)
  begin
    for i in 0 to 3 loop
      out1(i) <= not in1(i);
    end loop;
  end process;
                             end for ex arch;
end for ex arch;
```

# **Summary**



- Basic Structure of a VHDL Module
  - 1) Library Declaration
  - 2) Entity Declaration
    - External Signal (I/O Pins)
  - 3) Architecture Body
    - Internal Signal
    - Architectural Design Methods
      - ① Data Flow Design (concurrent statements)
      - ② Structural Design ("port map")
      - 3 Behavioral Design (sequential statements)
    - Concurrent vs. Sequential Statements
    - Design Constructions

# Review: Basic Gates in Logic Circuits



| 2-in | put |
|------|-----|
| AND  |     |





В

| Υ | = | A٠ | В |
|---|---|----|---|
|   |   |    |   |



| Α | Υ |
|---|---|
| 0 | 1 |
| 1 | 0 |

|   |   | _             |
|---|---|---------------|
| V | = | Δ             |
|   | _ | $\overline{}$ |

| Α | В | Y |
|---|---|---|
| 0 | 0 | 0 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

### **Review: NAND and NOR Gates**



 In many technologies, implementation of NAND gates or NOR gates is easier than that of AND or OR gates.

- NAND Gate:



| Α | В | Υ |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 1 |
| 1 | 0 | 1 |
| 1 | 1 | 0 |

$$Y = \overline{A \cdot B}$$

– NOR Gate:

| Α   | В | Υ |
|-----|---|---|
| 0 0 | 0 | 1 |
| 0   | 1 | 0 |
| 1   | 0 | 0 |
| 1   | 1 | 0 |

$$Y = \overline{A + B}$$

 Any logic function can be realized using only NAND gates or only NOR gates.

## **Review: Tristate Logic**



- The concept of tristate logic is also essential in digital system designs.
  - Directly connecting outputs of two gates together might not operate properly, and might cause damage to the circuit.
  - One ways is to use tristate buffers.
- Tristate buffers are gates with a high impedance state (High-Z or Z) in addition to high and low logic states.

High impedance state is equivalent to an open circuit.

Tristate buffer symbol



Truth table

| A | В | Output |
|---|---|--------|
| 0 | 0 | High-Z |
| 0 | 1 | 0      |
| 1 | 0 | High-Z |
| 1 | 1 | 1      |



### **Review: Buffer Gate**



- Double inversion would "cancel" each other out.
  - A weak signal may be amplified by means of two inverters.
- For this purpose, a special logic gate called a buffer gate is manufactured to perform the double inversion.
  - Its symbol is simply a triangle, with no inverting "bubble" on the output terminal:

Double inversion

"Buffer" gate





| Input | Output |
|-------|--------|
| 0     | 0      |
| 1     | 1      |